package com.alibaba.model.param;

import jakarta.validation.constraints.*;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.math.BigDecimal;

/**
 * 商品请求参数类
 * 用于新增或修改商品
 * 不包含数据库自动生成字段
 * @author ZhouYaDong
 * @date 2025/9/28
 */

@Data
@NoArgsConstructor
@AllArgsConstructor
public class GoodsParam {

    /**
     * 商品ID（修改时需要传）
     */
    @Null(groups = Add.class, message = "新增时ID必须为空")
    @NotNull(groups = Update.class, message = "修改时ID不能为空")
    private Long id;

    /**
     * 商品名称
     */
    @NotBlank(message = "商品名称不能为空")
    @Size(max = 100, message = "商品名称长度不能超过100字符")
    private String name;

    /**
     * 商品价格
     */
    @NotNull(message = "商品价格不能为空")
    @DecimalMin(value = "0.00", inclusive = false, message = "商品价格必须大于0")
    private BigDecimal price;

    /**
     * 库存数量
     */
    @NotNull(message = "库存数量不能为空")
    @Min(value = 0, message = "库存数量不能为负数")
    private Integer stock;

    /**
     * 商品状态（1=上架, 0=下架）
     */
    @NotNull(message = "商品状态不能为空")
    @Min(value = 0, message = "商品状态只能为0或1")
    @Max(value = 1, message = "商品状态只能为0或1")
    private Integer status;

    /**
     * 浏览量（可选，如果前端不传可默认 0）
     */
    @Min(value = 0, message = "浏览量不能为负数")
    private Long viewCount;

    /**
     * 新增分组
     */
    public interface Add {}
    /**
     * 修改分组
     */
    public interface Update {}
}
